package cn.edu.ctbu.jpatest.dao;

import cn.edu.ctbu.jpatest.entity.Course;
import jakarta.transaction.Transactional;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;

import java.util.List;

/**
 * @author xiaopeng
 * @version 1.0
 */
public interface CourseRepository extends JpaRepository<Course,String> {

    /**
     * 根据课程名称模糊查询
     * @param cname
     * @return
     */
    List<Course> findByNameLike(String cname);

    /**
     * 根据课程编号查询
     * @param cno
     * @return
     */
    Course findByCno(String cno);

    /**
     * 根据课程编号更新课程人数
     * @param cno
     * @param cNums
     * @return
     */
    @Modifying
    @Transactional
    @Query("UPDATE tb_course c SET c.nums = :cNums WHERE c.cno = :cno")
    void updateCNums(@Param("cno") String cno,@Param("cNums") Integer cNums);

    /**
     * 根据课程编号删除
     * @param cno
     * @return
     */
    void deleteByCno(String cno);
}
